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IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 

In Re The Application of: 
Arthur Lin et al. 

Serial No.: not yet assigned 

Filed: herewith 

For: ROUTER WITH CLASS OF 
SERVICE MAPPING 



Cesari and McKenna, LLP 
30 Rowes Wharf 
Boston, MA 02110 
July 14, 2000 



Examiner: not yet assigned 
Art Unit: not yet assigned 



Honorable Assistant Commissioner for Patents 
Washington, D.C. 20231 

Sir: 

PRELIMINARY AMENDMENTS 



Please cancel claims 1-29 and insert the following new claims 30-44 as set forth 

below: 

30. A router for use in routing packets over a network, the router supporting a plurality, 
X, of classes of service and including: 

A. a plurality of input ports for receiving packets over the network; 

B. a plurality of output ports for transferring packets over the network; 

C. a classifier for assigning packets received by the input ports to X * Y classes 
of service, where * represents multiplication, and mapping the XY classes of service to 
the X classes of service that are supported by the router, the classifier assigning to the 
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packet one of Y associated levels of priority, wherein each level of priority is associated 
with a different probability of packet loss; 

D. a buffer subsystem for retaining the packets in class of service per output port 
queues based on probabilities of discard associated with the X * Y classes of service; and 

E. a scheduler for transferring the packets from the buffer through each of the 
output ports based on the X classes of service. 

31. The router of claim 30 wherein the buffer subsystem includes multiple storage loca- 
tions and links available storage locations in a free queue. 

32. The router of claim 31 wherein the buffer subsystem includes a processor that deter- 
mines: 

i. a new weighted average depth for the free queue, and 

ii. a probability of discard for a given packet if the new weighted average queue 
depth falls below a predetermined maximum threshold associated with the class of serv- 
ice to which the packet is assigned by the classifier. 

33. The router of claim 32 wherein the buffer subsystem discards a given packet if the 
associated new weighted average depth for the'free queue falls below a minimum thresh- 
old associated with the class of service to which the packet is assigned. 

34. The router of claim 33 wherein the buffer subsystem processor calculates the prob- 
ability of discard as P d = c-(m* Anew) where c is an intercept and m is a slope that is as- 
sociated with a line that plots average free queue depth versus probability of discard for 
the class of service to which the packet is assigned, and Anew is the new weighted aver- 
age depth of the free queue. 

35. The router of claim 34 wherein the buffer subsystem processor calculates the new 
weighted average depth of the free queue as Anew = Acurrent + w(I-Acurrent) where w 
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is a weighting factor, I represents the instantaneous depth of the free queue and Acurrent 
is the current weighted average depth of the free queue. 

36. The router of claim 35 wherein the scheduler selects from the buffer subsystem 
packets for transfer based on weighting factors associated with the respective 2 n classes 
of service. 

37. A router for use in routing packets over a network, the router supporting a plurality, 
X, of classes of service and including: 

A. a plurality of input ports for receiving packets over the network; 

B. a plurality of output ports for transferring packets over the network; 

C. a multiple storage location buffer for retaining packets to be transferred 
through the output ports; 

D. a buffer subsystem for retaining the packets in class of service per output port 
queues based on probabilities of discard associated with X*Y classes of service, where * 
represents multiplication; and 

E. a scheduler for transferring the packets from the buffer subsystem through each 
of the output ports based on the X classes of service that the router supports. 

38. The router of claim 37 further including a classifier for: 

i. assigning packets received by the input ports to X* Y classes of service, 

ii. associating the packets with the X* Y classes of service that are supported by 
the router, and 

iii. assigning to the packet one of X*Y associated levels of priority, wherein each 
level of priority is associated with a different probability of packet loss. 

39. The router of claim 38 wherein the buffer subsystem includes a processor that deter- 
mines 

i. a new weighted average queue depth for a free queue that links available buffer 
storage locations, and 
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iL a probability of discard for a given packet if the new weighted average free 
queue depth fails below a predetermined maximum threshold associated with the class of 
service to which the packet is assigned. 

40. The router of claim 39 wherein the buffer subsystem processor calculates the prob- 
ability of discard as Pd = c-(m*ANEw) where c is an intercept and m is a slope that are as- 
sociated with a line that plots average free queue depth versus probability of discard for 
the class of service to which the packet is assigned, and A NEW is the new weighted aver- 
age depth of the free queue. 

4L The router of claim 40 wherein the buffer subsystem processor calculates the new 
depth of the weighted average free queue as Anew = Acurrent + w (I-Acurrent) where w 
is a weighting factor, I represents the instantaneous depth of the free queue and Acurrent 
is the current weighted average depth of the free queue. 

42. The router of claim 41 wherein the buffer subsystem discards a given packet if the 
new weighted average free queue depth falls below a minimum threshold associated with 
the class of service to which the packet is assigned. 

43. The router of claim 41 wherein the buffer subsystem retains a given packet if the new 
weighted average free queue depth is above a maximum threshold associated with the 
class of service to which the packet is assigned. 

44. The router of claim 37 wherein the scheduler selects packets for transfer through 
each output port based on weighting factors associated with the respective 2 n classes of 
service. 
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REMARKS 

Please cancel pending claims 1-29 and include claims 30- 44 before examination. 
Please charge any additional fee occasioned by this paper to our Deposit Account 
No. 03-1237. 



Respectfully submitted, 




Patricia A. Sheehan 
Reg. No. 32,301 

CESARI AND MCKENNA, LLP 
30 Rowes Wharf 
Boston, MA 02110-2699 
(617) 951-2500 
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ROUTER WITH CLASS OF SERVICE MAPPING 

FIELD OF INVENTION 

The invention relates generally to routers and switches and, more particularly, to 
routers and switches that support multiple classes of service for packet routing. 

BACKGROUND OF THE INVENTION 

At network multiplexing points, such as switches or routers, the handling of 
frames or packets is generally determined by rules associated with classes of service to 
which given frames or packets are assigned* The classes of service essentially define 
acceptable packet or frame delays and probabilities of packet or frame loss. (As used 
herein, the term "packet" refers to both frames and packets, and the term "router" refers 
to both switches and routers.) 

The packets are typically assigned to classes of service based on information 
contained in the packet and/or traffic management rules established by either a network 
supervisor or a service provider. All packets assigned to the same class receive the same 
treatment. Being assigned to a "higher" class ensures that a packet will have a shorter 
maximum transmission delay and a lower probability of loss- Being assigned to a 
"lower" class may mean a longer delay and/or a greater probability of loss. 

Generally, the router maintains at each output port a buffer for holding packets in 
queues associated with the classes of service. The queues ensure that packets are 
delivered in order within the various classes of service, and that the associated rules for 
maximum delays and probabilities of loss can be enforced. Since each queue is 
essentially separately maintained, the more classes the router supports the more 
processing and storage capacity is required for a given number of output ports. To 
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support "x" classes, for example, the router must set aside buffer storage locations for 
each of the x queues at each of its "y" ports. Further, it must determine for each queue 
whether or not a next packet should be retained or discarded. The router thus makes x*y 
separate calculations based on queue length and/or available associated storage locations 
to determine whether to retain or discard the packets, where "*" represents multiplication. 

Network standards, such as the (revised) 802. lp standard, have relatively recently 
increased the number of classes of service to eight classes. Routers operating under prior 
standards support four classes of service, and thus, must be upgraded, for example, with 
increased storage capacities of the output port buffers, to support the increased number of 
classes. Such upgrading may be prohibitively expensive and/or it may not be feasible. 
Accordingly, what is needed is a mechanism to operate a router that supports a relatively 
small number of classes of service in an environment in which packets are assigned to a 
greater number of classes. Such a mechanism should, without requiring the enlarged 
storage and processing capabilities conventionally associated with supporting the greater 
number of classes, maintain service distinctions associated with the greater number of 
classes and more importantly retain the order of packets within each of the greater 
number of classes. 

SUMMARY OF THE INVENTION 

A router maps packets assigned to 2 n+m classes of service into 2 n classes of service 
and assigns the packets to 2 m levels of loss-priority within each of the 2 n classes. The 
router includes a classifier that uses n bits of an (n+m)-bit "class of service identifier" to 
map the packets to the 2 n classes, and the remaining m bits to assign the loss priorities. 
The router then controls packet retention/discard with a modified weighted random early 
detection scheme based in part on the 2 n+m classes and in part on the 2 n classes, to 
maintain the probability of loss distinctions and in-order packet handling associated with 
the 2 n+m classes. 

A scheduler controls the transmission of packets by each output port based on the 
2 n classes of service. The scheduler uses a weighted round robin scheme to ensure that 



2 



H:\l 12\025\0071\PROSECUT\PATAPP2.DOC 



PATENT 
112025-0067 

packets from each of the classes are transmitted by each of the output ports within the 
prescribed maximum delay limits associated with the 2 n+m classes of service. 

The router includes an output buffer that holds the packets for all of the router's 
output ports. The router maintains a "free queue," which links the buffer storage 
locations available for packet storage. To determine whether to retain or discard a given 
packet, the router compares a weighted average depth of the free queue with 
predetermined maximum and minimum thresholds that are associated with the particular 
one of the 2 n+m classes of service to which the packet is assigned. If the weighted average 
exceeds the associated maximum threshold, the router retains the packet in a storage 
location that is then removed from the free queue and linked to a class of service per 
output port queue that corresponds to the class of service to which the packet is mapped 
by the classifier. If the weighted average depth falls below the associated minimum 
threshold, the router discards the packet. If the weighted average depth falls between the 
associated minimum and maximum thresholds, the router calculates a probability of 
discard and compares the probability to a "random" value. The router discards the 
packet if the probability exceeds the random value, and otherwise retains the packet. 

The maximum and minimum thresholds are set relative to one another such that 
the loss priorities associated with the 2 n+m classes are maintained. As discussed below, 
the router makes only one weighted average queue depth calculation for the free queue, 
and uses this calculation to determine whether to retain or discard packets for the 2 n 
classes of service. This is in contrast to prior known routers that must maintain at each 
output port separate average queue depths for each of the class of service per port queues. 



BRIEF DESCRIPTION OF THE DRAWINGS 

The invention description below refers to the accompanying drawings, of which: 
Fig. 1 is a functional block diagram of a network that includes routers that are 
constructed and operate in accordance with the invention; 

Fig. 2 is a functional block diagram of a router of Fig. 1 ; 
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Fig. 3 illustrates a mapping of packets to classes of service; 
Fig. 4 is a flow chart of the operations of the router of Fig. 2; and 
Fig. 5 is a graph of weighted average queue depth versus probability of packet 
discard. 

DETAILED DESCRIPTION OF AN ILLUSTRATIVE EMBODIMENT 

Referring now to Fig. 1, a network 10 includes a plurality of endstations 12 and 
nodes 14 that transmit packets to other endstations 12 and nodes 14 through routers 16 
and 17. The endstations 12 and nodes 14 assign packets to classes of service based on 
information contained in the packets and/or on predetermined traffic management rules 
that are provided by the network manager and/or various service providers. The classes 
of service are essentially associated with maximum limits for transmission delays and 
probabilities of packet loss. Higher classes are associated with shorter maximum delays 
and lower probabilities of packet loss. Packets that must be delivered as essential parts of 
a transmission are, for example, assigned to a higher class then are packets that contain 
non-essential information. 

Preferably, the endstation 12 or the node 14 that introduces the packet to the 
network assigns the packet to one of 2 n+m classes of service. To inform the routers 16 and 
17 of the assignment, the endstation 12 or node 14 writes an appropriate class of service 
"tag" to a COS identifier field in the header that is included in the packet. The COS 
identifier field has three bits, as defined by (revised) standard 802. Ip, and the packet is 
thus assigned to one of eight classes of service, i.e., 1 of 2 3 classes. The packet is then 
forwarded by the endstation 12 or node 14 over the network 10 to an input port 28 of a 
router 16 or 17. The router then transfers the packet through an output port 30 and over 
the network in accordance with the transmission rules and delay limits associated with the 
class of service to which the packet is assigned. 

The routers 17 support 2 n+m classes of service while the routers 16 support 2 n 
classes, where n<3. We discuss herein the operations of the routers 16 to assign packets 
to the various classes. Further, we discuss the operations that the routers 16 and/or the 
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routers 17 perform to determine whether to retain or discard a packet and/or when to 
transmit a packet. 

Referring now to Fig. 2, a router 16 includes a classifier 18 that associates a 
received packet with one of2 n+m classes of service, based primarily on the COS tag, if 
any, included in the packet header. The classifier maps the 2 n+m classes of service to the 
2 n classes based on, for example, the highest order n bits or the lowest order n bits of the 
COS tag. The classifier then uses the remaining bits of the COS tag to set the loss 
priorities of the packets. As discussed below, the loss priorities determine if respective 
packets are discarded or retained during times of congestion. The higher the loss priority 
of a packet, the less likely the packet will be retained. 

If the endstation 12 or node 14 that introduces the packet to the network does not 
support the 802. lp standard, the COS tag may not be included in the packet. The 
classifier 18 may then assign the packet to one of the 2 n+m classes, currently 2 3 classes, 
based on appropriate network or service provider transmission rules. It may, for example, 
assign the packet to a "best effort" class. Alternatively, the router 16 may assign the 
packet to a particular class of service based on a media access control, or MAC, address 
included in the packet. The classifier then writes the appropriate COS tag to the packet 
header. 

Referring now also to Fig. 3, the router 16 in this exemplary embodiment supports 
four classes of service, i.e., 2 2 classes. The classifier 18 maps each of the 2 3 classes of 
service to an appropriate one of the 2 classes of service based on the two highest order 
bits of the 3-bit COS tag. The third, or lowest order bit, is then used to assign a loss 
priority to the packet. The classifier 18 thus associates a packet that is assigned to class 
of service 010 with class of service 01 and sets the loss priority of the packet to 0. 
Further, the classifier 1 8 associates a packet that is assigned to class of service 011 with 
class 01 and sets the loss priority of this packet to 1 . 

Referring further to Fig. 4 once the classifier 1 8 associates the packets with the 
various 2 n classes of service and sets the loss priorities (steps 400-402), a policer 20 
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enforces network or service provider usage parameter controls by marking, discarding or 
passing the packets (step 404). The usage parameter controls are set by a network 
manager or service provider based on, for example, levels of service purchased by or 
associated with a user. The user may, for example, purchase a level of service based on 
the transmission of a maximum number of packets per hour. If the number of packets 
being sent by the user exceeds this limit, the policer then marks, discards or passes the 
excess packets depending on the traffic management rales. 

If the policer 20 marks an offending packet, it assigns the packet to a higher loss 
priority within the associated class of service. This increases the likelihood that the 
packet will be discarded if the network becomes congested. In the example, the policer 
sets the lowest order bit of the COS tag to 1. If the packet is already assigned the highest 
loss priority within the class of service, the policer 20 either passes or discards the packet, 
depending on the traffic management rules. If the packet is passed, the policer 20 may 
charge the user for the use of excess bandwidth. 

As discussed above, the policer 20 operates in accordance with traffic 
management rules established by a network manager or service provider. In the 
embodiment described herein the policer determines if a packet exceeds an established 
limit by using a "jumping window policing scheme." The policer thus sets a police rate 
of B/T for a user, where B is a burst size and T is a time interval and both B and T are set 
by the network manager or service provider. The policer then counts the number of 
octets received from the user over intervals of length T. If the count exceeds B, the 
arriving packet is marked, passed or dropped, depending on the enforcement mode 
utilized by the policer. Various limits may be set, such as, for example, limits that vary 
based on the number of times the associated policing rate is exceeded by a given user 
and/or based on the various classes of service. 

A WRED processor 22 determines which of the remaining packets, i.e., the 
packets that the policer has not discarded, are to be retained in a buffer 24 that holds the 
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packets for every output port 30 (steps 406-416). The use of a single buffer is in contrast 
to prior known routers that use a separate buffer for each output port. 

The WRED processor 22 utilizes a modified weighted-random early detection 
(WRED) scheme. The WRED processor associates with each of the 2 n+m classes of 
service, "Q," two thresholds, namely, a maximum threshold MAXq and a minimum 
threshold MIN C . As discussed below, the thresholds are used by the processor 22 to 
determine whether to retain or discard a given packet. 

The WRED processor 22 keeps track of an average "free queue" depth, which is 
an average number of available storage locations in the buffer 24. When the buffer is 
empty, all of the buffer storage locations are linked to the free queue. As packets are 
retained, buffer locations, which are generally referred to in 512 byte pages, are removed 
from the free queue and linked to appropriate class of service per output port queues. 
When the packets are later transmitted, the buffer locations are removed from the class of 
service per output port queues and again linked to the free queue. 

Each time a packet is received, the WRED processor 22 determines a new 
weighted average free queue depth A NEW : 

Anew = ^current + ^(I-Acurrent) 

where I is the instantaneous size of the free queue, W is the weighting factor and 
^current is the current weighted average free queue depth (step 406). The weighting 
factor W is preferably selected such that multiplication is accomplished by shifting the 
difference value (I-Ac URRENT ). The value Ac^re^- is updated at regular intervals with 
the value of A NEW , such as after every 64B frame time, which approximates the average 
packet arrival time. 

The WRED processor compares the weighted average A^ E ^ with the MAX C . and 
MIN C values associated with the appropriate one of the 2 n+m classes of service. If the 
weighted average exceeds the MAXc. value, the WRED processor 22 retains the packet 
(step 408). If the weighted average falls below the MIN C . value, the WRED processor 22 



7 



H:\l 12\025\0071\PROSECUT\PATAPP2.DOC 



PATENT 
112025-0067 

discards the packet (step 410). If, however, the average falls between MAX C . and MIN C 
values, the WRED processor calculates a probability of discard, P D ; 

P D = b c .-(m c .*A NEW ) 

where b c . and m c . are the slope and intercept values associated with the appropriate one of 
the 2 n+m classes of service (step 412). As shown in Fig. 5, the probability of discard 
changes linearly with changes in the weighted average queue depth. A given packet is 
discarded when the probability of discard P D exceeds a "random" number that is 
produced by a pseudo random generator 25 (steps 414-416). When the weighted average 
is relatively low, the probability of discard is larger, and thus, the packet is more likely to 
be discarded. 

The slope and intercept values m c . and b c . are selected based on trade-offs between 
keeping links through the router 16 busy and reserving space in the buffer 24 to handle 
bursts. For higher classes of service the slope and intercept values are selected to be 
relatively low - such that the probability of discard is low over the entire range from 
MAX C . to MIN C .. The slope and intercept values for the lower classes of service are 
typically larger, reflecting the greater associated probability of packet loss for the class 
and the reservation of spaces in the buffer for bursts of packets assigned to the higher 
classes. The various threshold values, and slope and intercept values are selected such 
that packet order and probabilities of packet loss are maintained across the 2 n+m classes of 
service. 

In prior known routers, implementing a WRED scheme required maintaining 
average queue depths for all of the classes of service queues at each of the output ports. 
Thus, for a router to support 8 classes of service over "y" output ports, it had to calculate 
average queue depths for 8*y separate queues. In the current router 16, the WRED 
processor calculates the average depth of a single free queue, regardless of the number of 
classes of service. 

A scheduler 26 implements a 2" class-based weighted round robin (WRR) 
scheduling scheme for each output port (step 418). The scheduler associates an 
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appropriate weighting factor W Q with each class of service per output port queue. The 
scheduler de-queues Wq. packets for transfer from the Qj queue associated with one of the 
2 n classes of service, and then de-queues W Qj+i packets from the Q j+ , queue for 
subsequent transfer. If the Q j+1 queue is empty, the scheduler de-queues an appropriate 
number of packets from the Q j+2 queue, and so forth. The scheduler 26 thus ensures that 
each one of the 2 n classes of service is associated with an appropriate maximum delay 
limit and through-put allocation. 

The class of service mapping, modified WRED scheme and WRR scheme in 
combination ensure that packets are transferred through the router 16 as if the router 
supported the 2 n+m classes of service. The router 16, however, requires less processing 
and storage overhead than the prior known routers that support the same number of 
classes, since the router 16 actually supports 2 n classes of service, and uses a single 
output buffer to do so. 

What is claimed is: 
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CLAIMS 

1 . A router for use in routing packets over a network, the router supporting 2 n classes of 
service and including: 

A. a plurality of input ports for receiving packets over the network; 

B. a plurality of output ports for transferring packets over the network; 

C. a classifier for assigning packets received by the input ports to 2 n+m classes of 
service and mapping the 2 n+m classes of service to the 2 n classes of service that are 
supported by the router, the classifier assigning to the packet one of 2 m associated levels 
of priorit^, wherein each level of priority is associated with a different probability of 
packet loss; 

D. means for retaining the packets based on probabilities of discard associated 
with the 2 n+m classes of service; and 

E. scheduling means for transferring the packets through each of the output ports 
based on the 2 n classes of service. 

2. The router of claim 1 further including a multiple storage location buffer for retaining 
packets to be transferred through the output ports, the buffer linking the storage locations 
that contain packets in class of service per output port queues and linking available 
storage locations in a free queue. 

3. The router of claim 2 wherein the means for retaining the packets further includes: 

L means for determining a new weighted average depth for the free queue, and 
ii. means for determining a probability of discard for a given packet if the new 

weighted average queue depth falls below a predetermined maximum threshold 

associated with the class of service to which the packet is assigned. 

4. The router of claim 3 wherein the discard means discards a given packet if the 
associated new weighted average depth for the free queue falls below a minimum 
threshold associated with the class of service to which the packet is assigned. 
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5. The router of claim 4 wherein the discard means calculates the probability of discard 
as P d = c-(m* A NEW ) where c is an intercept and m is a slope that is associated with a line 
that plots average free queue depth versus probability of discard for the class of service to 
which the packet is assigned, and A NEW is the new weighted average depth of the free 
queue. 

6. The router of claim 5 wherein the discard means calculates the new weighted average 
depth of the free queue as A NEW = A^rj^nj + w^-A^^re^) where w is a weighting 
factor, I represents the instantaneous depth of the free queue and Ac URRENT is the current 
weighted average depth of the free queue. 

7. The router of claim 6 wherein the scheduling means selects packets for transfer based 
on weighting factors associated with the respective 2 n classes of service. 

8. A router for use in routing packets over a network, the router supporting 2 n classes of 
service and including: 

A. a plurality of input ports for receiving packets over the network; 

B. a plurality of output ports for transferring packets over the network; 

C. a multiple storage location buffer for retaining packets to be transferred 
through the output ports; 

D. means for retaining the packets based on probabilities of discard associated 
with 2 n+m classes of service; and 

E. scheduling means for transferring the packets through each of the output ports 
based on the 2 n classes of service that the router supports. 

9. The router of claim 8 further including a classifier for: 

i. assigning packets received by the input ports to 2 n+m classes of service, 
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ii. associating the packets with the 2 n classes of service that are supported by the 
router, and 

iii. assigning to the packet one of 2 m associated levels of priority, wherein each 
level of priority is associated with a different probability of packet loss. 

10. The router of claim 9 wherein the means for retaining the packets further includes 

i. means for determining a new weighted average queue depth for a free queue 
that links available buffer storage locations, and 

ii. means for determining a probability of discard for a given packet if the new 
weighted^ average free queue depth falls below a predetermined maximum threshold 
associated with the class of service to which the packet is assigned. 

1 1 . The router of claim 1 0 wherein the discard means calculates the probability of 
discard as P d = c-(m* A NEW ) where c is an intercept and m is a slope that are associated 
with a line that plots average free queue depth versus probability of discard for the class 
of service to which the packet is assigned, and A NEW is the new weighted average depth 
of the free queue. 

12. The router of claim 1 1 wherein the discard means calculates the new depth of the free 
queue as A NEW = Ac URRENT + w (I-Ac URRENT ) where w is a weighting factor, I represents 
the instantaneous depth of the free queue and Ac URRENT is the current weighted average 
depth of the free queue. 

13. The router of claim 12 wherein the discard means discards a given packet if the new 
weighted average free queue depth falls below a minimum threshold associated with the 
class of service to which the packet is assigned. 

14. The router of claim 12 wherein the discard means retains a given packet if the new 
weighted average free queue depth is above a maximum threshold associated with the 
class of service to which the packet is assigned. 
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15. The router of claim 8 wherein the scheduling means selects packets for transfer 
through each output port based on weighting factors associated with the respective 2 n 
classes of service. 

1 6. The router of claim 1 5 wherein the buffer links retained packets in class of service 
per output port queues and the scheduling means selects packets from the class of service 
per output port queues. 

17. A method of routing packets through a router that supports 2 n classes of service, the 
method including the steps of: 

A. receiving packets through one or more input ports; 

B. assigning packets received by the input ports to 2 n+m classes of service and 
mapping the 2 n+m classes of service to the 2 Q classes of service that are supported by the 
router, the classifier assigning to the packet one of 2 m associated levels of priority, 
wherein each level of priority is associated with a different probability of packet loss; 

C. retaining the packets based on probabilities of discard associated with the 2 n+m 
classes of service; and 

D. transferring the packets through one or more output ports based on the 2 n 
classes of service. 

18. The method of routing packets of claim 17 further including in the step of retaining 
the packets the steps of : 

L retaining the packets in a multiple storage location buffer and linking available 

storage locations to a free queue, 

ii. determining a new weighted average depth for the free queue, and 

iiL determining a probability of discard for a given packet if the new weighted 

average queue depth falls below a predetermined maximum threshold associated with the 

class of service to which the packet is assigned. 
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1 9. The method of routing packets of claim 1 8 including in the step of retaining the 
packets the further step of discarding a given packet if the new weighted average depth 
for the free queue falls below a minimum threshold associated with the class of service to 
which the packet is assigned. 

20. The method of routing packets of claim 19 wherein the step of retaining the packets 
includes calculating the probability of discard as P d - c-(m* A NEW ) where c is an intercept 
and m is a slope associated with a line that plots weighted average free queue depth 
versus probability of discard for the class of service to which the packet is assigned, and 
A NEW is the new weighted average depth of the free queue. 

21 . The method of routing packets of claim 20 wherein the step of retaining the packets 
includes calculating the new weighted average depth of the free queue as A NEW = 
^current + w (I-Acurrent) where w is a weighting factor I represents the instantaneous 
depth of the free queue and Ac URRENT is the current weighted average queue depth. 

22. The method of claim 21 wherein the discard means retains a given packet of the new 
weighted average free queue depth is above a maximum threshold associated with the 
class of service to which the packet is assigned. 

23. The method of routing packets of claim 17 wherein the step of transferring packets 
through the more or more output port transfers the packets based on weighting factors 
associated with the respective 2 n classes of service. 

24. A method of routing packets through a router that supports 2 n classes of service, the 
method including: 

A. receiving packets through one or more input ports and assigning the packets to 
2 n+m classes of service; 
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B. retaining packets based on probabilities of discard associated with the 2 n+m 
classes of service in a multiple storage location buffer that links available storage 
locations to a free queue; and 

C. transferring the packets through one or more output ports based on the 2 n 
classes of service. 

25. The method of routing of claim 24 further including the steps: 

i. associating the packets that are assigned to the 2 n+m classes of service with the 
2 n classes of service that are supported by the router, and 

iL assigning to the respective packets one of 2 associated levels of priority, 
wherein each level of priority is associated with a different probability of packet loss. 

26. The method of routing packets of claim 25 wherein the step of retaining the packets 
includes: 

a. determining a new weighted average depth for the free queue, and 

b. determining a probability of discard for a given packet if the new weighted 
average free queue depth falls below a predetermined maximum threshold associated with 
the class of service to which the packet is assigned. 

27. The method of routing packets of claim 26 wherein the step of retaining packets 
further includes calculating the probability of discard as P d = c-(m* A^^) where c is an 
intercept and m is a slope that are associated with a line that plots average free queue 
depth versus probability of discard for the class of service to which the packet is assigned, 
and A NEW is the new weighted average depth of the free queue. 

28. The method of routing packets of claim 27 wherein the step of retaining packets 
further includes calculating the new weighted average depth of the free queue as A NEW = 
Acurrent + w (I-Acurrent) where w is a weighting factor, I represents the instantaneous 
depth of the free queue and Ac URRENT is the current weighted average queue depth. 
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29. The method of routing packets of claim 26 wherein the step of retaining packets 
further includes discarding a given packet if the new weighted average free queue depth 
falls below a minimum threshold associated with the class of service to which the packet 
is assigned. 

29. The method of routing packets of claim 26 wherein the step of retaining packets 
further includes retaining a given packet if the new weighted average free queue depth is 
above the maximum threshold associated with the class of service to which the packet is 
assigned) 
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ABSTRACT OF THE DISCLOSURE 



A router includes a classifier that classifies packets assigned to 2 n m classes of 
service into 2 n classes of service that are supported by the router. The classifier then sets 
the loss priorities of the respective packets to one of m levels. The router uses a modified 
weighted random early detection scheme that is based on probabilities of discard 
associated with the 2 n+m classes of service to determine whether to retain or discard 
particular packets. The router uses a single buffer to store packets directed to all of the 
various output ports. The available storage locations in the buffer are linked to a free 
queue and a weighted average depth of the free queue, is used to determined whether or 
not to retain a given packet. The router compares the weighted average depth of the free 
queue to maximum and minimum thresholds associated with the particular 2 n+m class of 
service to which the packet is assigned. If the weighted average is above the maximum 
threshold, the packet is retained. If the weighted average is below the minimum 
threshold, the packet is discarded. If the weighted average is between the two thresholds, 
a probability of discard that is based on the 2 n+m classes of service is calculated and 
compared to a random value to determine whether or not the packet should be retained. 
If the probability of discard exceeds the random value, the packet is discarded. 
Otherwise, the packet is retained. The retained packets are then transferred through the 
various output ports of the router based on weighting factors associated with the 2 n 
classes of service. 
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As a below-named inventor, I hereby declare that: 

My residence, post-office address, and citizenship are as stated below next to my 

name. 

I believe I am an original, first, and joint inventor of the subject matter which is 
claimed and for which a patent is sought on the invention entitled ROUTER WITH 
CLASS OF SERVICE MAPPING, the specification of which was filed on December 31, 
1997, and accorded Serial Number 09/900,478 . 

I hereby state that I have reviewed and understand the contents of the above- 
identified application specification, including the claims, as amended by any amendment 
specifically referred to herein. 

I acknowledge the duty to disclose all information known to me that is material to 
patentability in accordance with Title 37, Code of Federal Regulations, §1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code 
§1 19(a)-(d) of any foreign application(s) for patent or inventor's certificate listed below 
and have also identified below any foreign application for patent or inventor's certificate 
filed by me on the same subject matter having a filing date before that of the application 
on which priority is claimed: None . 

I hereby claim the benefit under Title 35, United States Code §1 19(e) of the 
following U.S. provisional application: None . 

I hereby claim the benefit under Title 35, United States Code §120, of the United 
States Applications) listed below and, insofar as the subject matter of each of the claims 
of this application is not disclosed in the prior United States application in the manner 
provided by the first paragraph of Title 35, United State Code, §1 12, 1 acknowledge the 
duty to disclose all information that is material to patentability in accordance with 
Title 37, Code of Federal Regulations, §1.56, and which became available to me between 
the filing date of the prior application and the national or PCT international filing date of 
this application: None . 

I hereby declare that all statements made herein of my own knowledge are true 
and that all statements made on information and belief are believed to be true; and further 
that these statements were made with the knowledge that willful false statements and the 
like so made are punishable by fine or imprisonment or both under Section 1001 of 
Title 18 of the United States Code and that such willful false statements may jeopardize 
the validity of the application or any patent issued thereon. 
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I hereby appoint Michael E. Attaya, Reg. No. 31,731; Charles J. Barbas, Reg. 
No. 32,959; Joseph H. Born, Reg. No. 28,283; Robert A. Cesari, Reg. No. 18,381; Steven 
J. Frank, Reg. No. 33,497; Christopher K. Gagne, Reg. No. 36,142; William A. Loginov, 
Reg. No. 34,863; Robert A. Mazzarese, Reg. No. P42,852; John F. McKenna, Reg. 
No. 20,912; Martin J. O'Donnell, Reg. No. 24,204; Thomas C. O'Konski, Reg. 
No. 26,320; Michael R. Reinemann, Reg. No. 38,280; RitaM. Rooney, Reg. No. 30,585; 
Heather B. Shapiro, Reg. No. 41,305; and Patricia A. Sheehan, Reg. No. 32,301, Cesari 
and McKenna, LLP, 30 Rowes Wharf, Boston, Mass. 021 10, jointly, and each of them 
severally, my attorneys and attorney, with full power of substitution, delegation and 
revocation, to prosecute this application, to make alterations and amendments therein, to 
receive the patent and to transact all business in the Patent and Trademark Office 
connected therewith. Please direct all telephone calls to Patricia A. Sheehan at (617) 951- 
2500. Please address all correspondence to Patricia A. Sheehan. 
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